<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>

<body>
    <div id="demo">
        <p>三元表达式 - 今天天气：{{isHot? '炎热' : '凉爽'}}</p>
        <p>监视属性 - 今天天气: {{weather}}</p>
        <p>计算属性 - 今天天气: {{computedWeather}}</p>
        <p><button @click="isHot=!isHot">变天</button></p>
    </div>
    <script>
        new Vue({
            el: '#demo',
            data: {
                isHot: true,
                weather:'炎热'
            },
            /**
             * watch 配置监视属性
             */
            watch:{
                isHot:{
                    // 默认情况下，首次加载不执行
                    /**
                     * newValue: 最新值
                     * oldValue: 变化前的值
                     */
                    handler(newValue,oldValue){
                        console.log('handler this: ', this)
                        this.weather = newValue ? '炎热' : '凉爽'
                    }
                }
            },
            computed:{
                computedWeather(){
                    return this.isHot ? '炎热' : '凉爽'
                }
            }
        })
    </script>
</body>

</html>